class Observer {
  constructor (data) {
    this.walk(data)
  }
  // 遍历对象的所有属性 需要传递data对象
  walk (data) {
    // 1.判断data是否是对象
    if(!data || typeof data !== 'object'){
      return
    }
    // 2.遍历data对象的所有属性
    Object.keys(data).forEach(key => {
      this.defineReactive(data,key,data[key])
    })
  }

  // 调用object.defineProperty把属性转换成getter 和 setter
  defineReactive(obj,key,val){
    let that =  this
    // 负责收集依赖，并发送通知
    let dep = new Dep()
    // 如果val是对象，把val内部的属性转换成响应式数据
    this.walk(val)
    Object.defineProperty(obj,key,{
      enumerable:true,
      configurable:true,
      get() {
        // 收集依赖
        Dep.target && dep.addSub(Dep.target)
        return val
      },
      set(newValue){
        if(newValue === val){
          return
        }
        val = newValue
        // 如果val是对象，把val内部的属性转换成响应式数据
        that.walk(newValue)
        // 发送通知
        dep.notify()
      }
    })
  }
}